## **Deep Learning HDL Toolbox**<sup>™</sup> Getting Started Guide

# MATLAB®



R

**R**2021**b** 

#### **How to Contact MathWorks**



Latest news:

Phone:

www.mathworks.com

Sales and services: www.mathworks.com/sales\_and\_services

User community: www.mathworks.com/matlabcentral

Technical support: www.mathworks.com/support/contact\_us



 $\mathbf{X}$ 

508-647-7000

The MathWorks, Inc. 1 Apple Hill Drive Natick, MA 01760-2098

Deep Learning HDL Toolbox<sup>™</sup> Getting Started Guide

© COPYRIGHT 2020-2021 by The MathWorks, Inc.

The software described in this document is furnished under a license agreement. The software may be used or copied only under the terms of the license agreement. No part of this manual may be photocopied or reproduced in any form without prior written consent from The MathWorks, Inc.

FEDERAL ACQUISITION: This provision applies to all acquisitions of the Program and Documentation by, for, or through the federal government of the United States. By accepting delivery of the Program or Documentation, the government hereby agrees that this software or documentation qualifies as commercial computer software or commercial computer software documentation as such terms are used or defined in FAR 12.212, DFARS Part 227.72, and DFARS 252.227-7014. Accordingly, the terms and conditions of this Agreement and only those rights specified in this Agreement, shall pertain to and govern the use, modification, reproduction, release, performance, display, and disclosure of the Program and Documentation by the federal government (or other entity acquiring for or through the federal government) and shall supersede any conflicting contractual terms or conditions. If this License fails to meet the government's needs or is inconsistent in any respect with federal procurement law, the government agrees to return the Program and Documentation, unused, to The MathWorks, Inc.

#### Trademarks

MATLAB and Simulink are registered trademarks of The MathWorks, Inc. See www.mathworks.com/trademarks for a list of additional trademarks. Other product or brand names may be trademarks or registered trademarks of their respective holders.

#### Patents

 $MathWorks\ {\tt products}\ {\tt are}\ {\tt protected}\ {\tt by}\ {\tt one}\ {\tt or}\ {\tt more}\ {\tt U.S.}\ {\tt patents}.\ {\tt Please}\ {\tt see}\ {\tt www.mathworks.com/patents}\ {\tt for}\ {\tt more}\ {\tt information}.$ 

#### **Revision History**

September 2020Online onlyNew for Version 1.0 (Release 2020b)March 2021Online onlyRevised for Version 1.1 (Release 2021a)September 2021Online onlyRevised for Version 1.2 (Release R2021b)

# Contents

## Install and Set up Prerequisite Products and Third-Party Tools

| Deep Learning HDL Toolbox Product Description                                                                                                                         |                          |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|--|
| Use Deep Learning on FPGA Bitstreams                                                                                                                                  | 1-3                      |  |
| Configure FPGA Boards<br>Xilinx Zynq-7000 ZC706 Evaluation Board<br>Intel Arria 10 SoC Development Kit<br>Xilinx Zynq UltraScale+ MPSoC ZCU102 FPGA Development Board | 1-4<br>1-4<br>1-4<br>1-5 |  |
| JTAG Connection                                                                                                                                                       | 1-7                      |  |

#### **Tutorials**

## 2

| Try Deep Learning on FPGA with Only Five Additional Lines of MATLAB |     |
|---------------------------------------------------------------------|-----|
| Code                                                                | 2-2 |

## Install and Set up Prerequisite Products and Third-Party Tools

- "Deep Learning HDL Toolbox Product Description" on page 1-2
- "Use Deep Learning on FPGA Bitstreams" on page 1-3
- "Configure FPGA Boards" on page 1-4
- "JTAG Connection" on page 1-7

#### **Deep Learning HDL Toolbox Product Description**

Prototype and deploy deep learning networks on FPGAs and SoCs

Deep Learning HDL Toolbox<sup>™</sup> provides functions and tools to prototype and implement deep learning networks on FPGAs and SoCs. It provides pre-built bitstreams for running a variety of deep learning networks on supported Xilinx<sup>®</sup> and Intel<sup>®</sup> FPGA and SoC devices. Profiling and estimation tools let you customize a deep learning network by exploring design, performance, and resource utilization tradeoffs.

Deep Learning HDL Toolbox enables you to customize the hardware implementation of your deep learning network and generate portable, synthesizable  $Verilog^{\$}$  and  $VHDL^{\$}$  code for deployment on any FPGA (with HDL Coder<sup>™</sup> and Simulink<sup>®</sup>).

### **Use Deep Learning on FPGA Bitstreams**

The Deep Learning HDL Toolbox hardware support packages provide bitstreams that you can use to deploy various deep learning networks on the target platform.

This table illustrates the mapping between the target boards, data types, and bitstream names.

| Target Board                           | Data Type | Bitstream Name      |
|----------------------------------------|-----------|---------------------|
| Xilinx Zynq <sup>®</sup> -7000 ZC706   | single    | 'zc706_single'      |
| Xilinx Zynq-7000 ZC706                 | int8      | 'zc706_int8'        |
| Xilinx Zynq UltraScale™<br>ZCU102      | single    | 'zcu102_single'     |
| Xilinx Zynq UltraScale ZCU102          | int8      | 'zcu102_int8'       |
| Intel Arria® 10 SoC<br>development kit | single    | 'arrial0soc_single' |
| Intel Arria 10 SoC development<br>kit  | int8      | 'arrial0soc_int8'   |

For an example that illustrates how you can use these bitstreams names and deploy your network when running the workflow, see "Prototype Deep Learning Networks on FPGA and SoCs Workflow".

### **Configure FPGA Boards**

Prepare your target FPGA boards for deploying a deep learning network by configuring them to connect to your host computer.

#### Xilinx Zynq-7000 ZC706 Evaluation Board

To set up the board:

- **1** Plug in the power cord, and then connect the host computer to the FPGA board by using a JTAG cable.
- 2 Specify the SW4 switch settings to use the Digilent USB-TO-JTAG interface.

| Configuration Source              | SW4 switch 1 | SW4 switch 2 |
|-----------------------------------|--------------|--------------|
| None                              | 0            | 0            |
| Cable Connector J3                | 1            | 0            |
| Digilent USB-TO-JTAG<br>Interface | 0            | 1            |
| JTAG (flying lead)Header J62      | 1            | 1            |

This graphic shows the configuration settings for the Xilinx Zynq-7000 ZC706 Evaluation Board.



To learn more about the board configuration, see the Xilinx ZC706 Evaluation Board User Guide.

#### Intel Arria 10 SoC Development Kit

To set up the board:

- **1** Plug in the power cord, and then connect the host computer to the FPGA board by using a JTAG cable.
- **2** Specify the SW3 switch settings.

| Bit 1 | Bit 2 | Bit 3 | Bit 4 | Bit 5 | Bit 6 | Bit 7 | Bit 8 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| Off   | On    | On    | On    | On    | Off   | Off   | Off   |

**3** Connect two DDR4 plugin boards to the memory plugin slot.

This graphic shows the configuration settings for the Intel Arria 10 SoC development kit.



To learn more about the board configuration, see the Arria 10 SoC Development Kit User Guide.

#### Xilinx Zynq UltraScale+ MPSoC ZCU102 FPGA Development Board

To set up the board:

- 1 Plug in the power cord. If using JTAG, connect the FPGA board to the host computer by using a JTAG cable. If using Ethernet, connect the FPGA board to the host computer by using an Ethernet cable.
- 2 Configure the SW6 switch.

| Boot Mode | Mode Pins [3:0] | SW6 Switch Position [3:0] |
|-----------|-----------------|---------------------------|
| JTAG      | 0, 0, 0, 0      | on, on, on, on            |
| QSPI32    | 0, 0, 1, 0      | on, on, off, on           |
| SD        | 1, 1, 1, 0      | off, off, off, on         |

The SW6 default position is QSPI32. For the SW6 DIP switch, moving the switch towards the ON label is 0.

This graphic shows the location of the  $\mathsf{SW6}$  switch.



This graphic shows the configuration settings for the Xilinx Zynq UltraScale+  $^{\rm TM}$  MPSoC ZCU102 FPGA development board.



To learn more about the ZCU102 hardware setup, refer to the Xilinx documentation.

## **JTAG Connection**

| Vendor     | Required Hardware                                                                                                                                                                                                                                      | Required Software                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Intel      | USB Blaster I or USB<br>Blaster II download cable                                                                                                                                                                                                      | <ul> <li>USB Blaster I or II driver</li> <li>For Windows<sup>®</sup> operating systems: Quartus<sup>®</sup> Prime executable directory must be on system path.</li> <li>For Linux<sup>®</sup> operating systems: versions below Quartus II 13.1 are not supported. Quartus II 14.1 is not supported. Only 64-bit Quartus is supported. Quartus library directory must be on LD_LIBRARY_PATH <i>before</i> starting MATLAB<sup>®</sup>. Prepend the Linux distribution library path before the Quartus library on LD_LIBRARY_PATH. For example, /lib/x86_64-</li> </ul> |
| Xilinx     | <ul> <li>Digilent<sup>®</sup> download cable.</li> <li>If your board has an onboard Digilent USB-JTAG module, use a USB cable.</li> <li>If your board has a standard Xilinx 14 pin JTAG connector, use with HS2 or HS3 cable from Digilent.</li> </ul> | <ul> <li>Linux - gnu : \$QUARTUS_PATH.</li> <li>For Windows operating systems: Xilinx Vivado<sup>®</sup> executable directory must be on system path.</li> <li>For Linux operating systems: Digilent Adept2</li> </ul>                                                                                                                                                                                                                                                                                                                                                 |
|            | <ul> <li>FTDI USB-JTAG cable</li> <li>Supported for boards<br/>with onboard FT4232H,<br/>FT232H, or FT2232H<br/>devices implementing<br/>USB-to JTAG</li> </ul>                                                                                        | <ul> <li>Install these D2XX drivers.</li> <li>For Windows operating systems: 2.12.28 (64 bit)</li> <li>For Linux operating systems: 1.4.22 (64 bit)</li> <li>For the installation guide, see D2XX Drivers from the FTDI Chip website.</li> </ul>                                                                                                                                                                                                                                                                                                                       |
| Microsemi® | JTAG connection not suppor                                                                                                                                                                                                                             | ted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

**Note** When simulating your FPGA design through Digilent JTAG cable with Simulink or MATLAB, you cannot use any debugging software that requires access to the JTAG; for example, Vivado Logic Analyzer.

## **Tutorials**

# Try Deep Learning on FPGA with Only Five Additional Lines of MATLAB Code

Use the Deep Learning HDL Toolbox to deploy a pretrained deep learning network to a target board and identify objects on a live webcam connected to the development computer by adding only five lines of MATLAB code to the "Try Deep Learning in 10 Lines of MATLAB Code" example.

**1** To connect to a webcam and load the pretrained AlexNet network:.

```
camera = webcam; % Connect to the camera
net = alexnet; % Load the neural network
```

If you need to install the webcam and Alexnet add-ons, a message appears with a link to help you download the free add-ons using Add-On Explorer. Alternatively, see Deep Learning Toolbox Model *for AlexNet Network* and MATLAB Support Package for USB Webcams for installation instructions.

After you install Deep Learning Toolbox Model for AlexNet network, you can use it to classify images. AlexNet is a pretrained convolutional neural network (CNN) that has been trained on more than a million images and can classify images into 1000 object categories such as keyboard, mouse, cup, pencil, and so on.

**2** To set up the interface to the target board, create the workflow object, and deploy the network to the target board:

```
hT = dlhdl.Target('Xilinx');
hW = dlhdl.Workflow('Network',net,'Bitstream','zcu102_single','Target',hT);
hW.deploy;
```

**3** To show and classify live images:

```
while true
    im = snapshot(camera); % Take a picture
    image(im); % Show the picture
    im = imresize(im,[227 227]); % Resize the picture for alexnet
    [prediction, speed] = hW.predict(single(im),'Profile','on');
    [val, idx] = max(prediction);
    label = net.Layers(end).ClassNames{idx}; % Classify the image
    title(char(label)); % Show the class label
    drawnow
    end
```

Point the webcam at an object. The pretrained deep learning network reports what class of object it thinks the webcam is showing, classifying images until you press **Ctrl+C**. The code resizes the image for the network by using imresize.

For example, the network correctly classifies a coffee mug. Experiment with objects in your surroundings to see how accurate the network is.



For next steps, see "Deep Learning on FPGA Solution".

#### See Also

alexnet|dlhdl.Workflow|dlhdl.Target

#### **More About**

- "Prototype Deep Learning Networks on FPGA and SoCs Workflow"
- "Supported Networks, Layers, Boards, and Tools"